// mainjs应用入口 项目的初始化 全局通用的事情
import Vue from 'vue'
// 引入初始化样式文件 margin padding
import 'normalize.css/normalize.css'

// 引入elementUI
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'

import '@/styles/index.scss' // global css

// 引入根组件
import App from './App'
// 引入vuex
import store from './store'

// 引入路由router
import router from './router'

// 引入字体图标
import '@/icons' // icon

Vue.use(ElementUI) // 把elementUI中的组件注册为全局使用

import '@/permission' // 模块中如果有同步代码的话会立即执行
Vue.config.productionTip = false

// 注册全局组件
// 注册组件，传入一个选项对象 (自动调用 Vue.extend)
// Vue.component('my-component', { /* ... */ })
// import PageTools from '@/components/PageTools'
// Vue.component('PageTools', PageTools)
// Vue.component(PageTools.name, PageTools)// 这样写也可以
// 全局注册组件已经在components下的index.js

// 注册插件
import componentPlugin from '@/components'
Vue.use(componentPlugin)

// vue实例化
new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App) // 类比为template模板 把APP根组件进行渲染 底层的所有的子孙组件也会一起渲染
})
